package com.hfy.pcberpbackend.entity;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;

import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Pattern;
import javax.validation.constraints.Size;
import java.time.LocalDateTime;

/**
 * 客户实体类
 */
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("customers")
public class Customer {
    
    /**
     * 主键ID
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;
    
    /**
     * 客户代码
     */
    @NotBlank(message = "客户代码不能为空")
    @Size(min = 2, max = 20, message = "客户代码长度必须在2-20个字符之间")
    @TableField("customer_code")
    private String customerCode;
    
    /**
     * 客户名称
     */
    @NotBlank(message = "客户名称不能为空")
    @Size(min = 2, max = 30, message = "客户名称长度必须在2-30个字符之间")
    @TableField("customer_name")
    private String customerName;
    
    /**
     * 联系人电话
     */
    @NotBlank(message = "联系人电话不能为空")
    @Pattern(regexp = "^1[3-9]\\d{9}$", message = "联系人电话格式不正确")
    @TableField("contact_phone")
    private String contactPhone;
    
    /**
     * 公司地址
     */
    @TableField("company_address")
    private String companyAddress;
    
    /**
     * 业务经理ID
     */
    @NotNull(message = "业务经理不能为空")
    @TableField("manager_id")
    private Long managerId;
    
    /**
     * 公司名称
     */
    @NotBlank(message = "公司名称不能为空")
    @Size(min = 2, max = 100, message = "公司名称长度必须在2-100个字符之间")
    @TableField("company_name")
    private String companyName;
    
    /**
     * 状态
     */
    @NotBlank(message = "状态不能为空")
    @Pattern(regexp = "^(active|inactive)$", message = "状态必须是active或inactive")
    @TableField("status")
    private String status;
    
    /**
     * 逻辑删除
     */
    @TableLogic
    @TableField("deleted")
    private Integer deleted;
    
    /**
     * 创建时间
     */
    @TableField(value = "created_at", fill = FieldFill.INSERT)
    private LocalDateTime createdAt;
    
    /**
     * 更新时间
     */
    @TableField(value = "updated_at", fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updatedAt;
    
    /**
     * 业务经理姓名（关联查询字段，不存储在数据库）
     */
    @TableField(exist = false)
    private String managerName;
} 